using System.ComponentModel.DataAnnotations.Schema;
using System.Data.Entity.ModelConfiguration;

namespace QldtSdh.DAL.Models.Mapping
{
    public class NghienCuuSinhMap : EntityTypeConfiguration<NghienCuuSinh>
    {
        public NghienCuuSinhMap()
        {
            // Khoá chính
            this.HasKey(t => t.MaNCSGUID);

            // Các cột
            this.Property(t => t.MaNCSGUID)
                .IsRequired()
                .HasMaxLength(50);

            this.Property(t => t.HoDem)
                .IsRequired()
                .HasMaxLength(255);

            this.Property(t => t.Ten)
                .IsRequired()
                .HasMaxLength(255);

            this.Property(t => t.NoiSinh)
                .HasMaxLength(255);

            this.Property(t => t.QuocTich)
                .IsRequired()
                .HasMaxLength(255);

            this.Property(t => t.DiaChi)
                .HasMaxLength(255);

            this.Property(t => t.SoDienThoai)
                .HasMaxLength(50);

            this.Property(t => t.Email)
                .HasMaxLength(255);

            // Ánh xạ Property của POCO vào Column của Table
            this.ToTable("NghienCuuSinh");
            this.Property(t => t.MaNCSGUID).HasColumnName("MaNCSGUID");
            this.Property(t => t.HoDem).HasColumnName("HoDem");
            this.Property(t => t.Ten).HasColumnName("Ten");
            this.Property(t => t.GioiTinh).HasColumnName("GioiTinh");
            this.Property(t => t.NgaySinh).HasColumnName("NgaySinh");
            this.Property(t => t.NoiSinh).HasColumnName("NoiSinh");
            this.Property(t => t.QuocTich).HasColumnName("QuocTich");
            this.Property(t => t.DiaChi).HasColumnName("DiaChi");
            this.Property(t => t.SoDienThoai).HasColumnName("SoDienThoai");
            this.Property(t => t.Email).HasColumnName("Email");
            this.Property(t => t.MaNganhDaoTaoNCSGUID).HasColumnName("MaNganhDaoTaoNCSGUID");
            this.Property(t => t.MaKhoaHocNCSGUID).HasColumnName("MaKhoaHocNCSGUID");

            this.HasRequired(t => t.KhoaHocNCS)
                .WithMany(t => t.ListNghienCuuSinh)
                .HasForeignKey(t => t.MaKhoaHocNCSGUID);

            this.HasRequired(t => t.NganhDaoTaoNCS)
                .WithMany(t => t.ListNghienCuuSinh)
                .HasForeignKey(t => t.MaNganhDaoTaoNCSGUID);
        }
    }
}
